"""
给定一组不含重复元素的整数数组 nums，返回该数组所有可能的子集（幂集）。

说明：解集不能包含重复的子集。

示例:

输入: nums = [1,2,3]
输出:
[
  [3],
  [1],
  [2],
  [1,2,3],
  [1,3],
  [2,3],
  [1,2],
  []
]

来源：力扣（LeetCode）
链接：https://leetcode-cn.com/problems/subsets
著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
"""
from typing import List


class Solution:
    def subsets(self, nums: List[int]) -> List[List[int]]:
        ans = []

        def backtrack(combination, start ):
            ans.append(combination)
            for i in range(start, length):
                backtrack(combination + [nums[i]], i+1)


        length = len(nums) 
        backtrack([], 0)
        return ans



if __name__ == "__main__":
    res = Solution().subsets([1,2,3])
    print(res)
